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(54) Method for obtaining from a block turbo-code an error correcting code of desired parameters 



(57) The present invention concerns a method for 
obtaining an error correcting code of a given first size 
(A/), including a systematic information part of a given 
second size (K) and a redundancy part. A block turbo- 
code is first obtained from said systematic information 
part and from predetermined inf ormation elements pro- 
vided at known locations, said block turbo-code consist- 
ing in a product of elementary systematic block codes, 



at least said predetermined information elements being 
removed from the obtained block turbo-code to produce 
a shortened block turbo-code. An additional error cor- 
recting code is derived from at least a portion of said 
shortened block turbo-code and said shortened block 
turbo-code is stuffed with stuffing elements so as to at- 
tain said given first size, said stuffing elements being 
information elements of said additional error correcting 
code. 



O 
N 
O 

CO 

Q. 
LU 




Fig. 7B 



□ shortened 

□ stuffed 



Printed by Jouve, 75001 PARIS (FR) 



i 



EP 1 317 070 A1 

Description 

[0001 J The present invention concerns in general terms a method for obtaining from a block turbo-code an error 
correcting code of desired parameters. The invention concerns also a method for decoding such an error correcting 
5 code. 

[0002] As it is well known, turbo-codes were originally introduced by C. Berrou, A. Glavieux and P. Thitimajshima in 
an article entitled "Near Shannon Limit Error Correcting and Decoding: Turbo-codes 0 published in ICC-1993 Confer- 
ence Proceedings, pages 1064-1070. Turbo-codes have subsequently been the subject of many developments. 
[0003] Broadly speaking, the turbo-coding principle is based on the concatenation of a plurality of elementary coding 
io steps, each using a simple code, hereinafter referred to as elementary code. The elementary coding steps are separated 
by interleaving steps modifying the order in which the data is taken into account. 

[0004] Two large classes of turbo-codes are distinguished: parallel turbo-codes where the elementary coding steps 
are carried out in parallel and serial turbo-codes where the elementary coding steps are earned out sequentially. Block 
turbo-codes (BTCs) are a special class of serial turbo-codes where the elementary codes are block codes like Hamming, 

15 RS (Reed Solomon) or BCH (Bose-Chaudhuri-Hocquenghem) codes. 

[0005] Fig. 1 illustrates schematically the structure of a block turbo-coder. The block turbo-coder 100 comprises 
elementary block coders 110 1 ,.. l 110 P concatenated in series, where Pis called the dimension of the turbo-code. The 
turbo-coder operates on data block of P dimensions, each elementary coder operating on one dimension only. Without 
loss of generality, it will be assumed in the following that P=2. 

20 [0006] A block of data represented by a matrix of fcjxife symbols is input to a first block coder 110-,. It should be noted 
that, depending on the type of block code, the symbols may be bits or words. The first block coder 110 1 operates on 
the rows (or the columns) of the matrix and appends to the original data (also called the systematic information or the 
systematic part) a first redundar^Mnfowwation^of redundancy part, he;* represented by a dotted area) to form a matrix: 
of size ^x/^. The second block coder 110 2 operates on the columns (or the rows) of the n^xk^ matrix and appends 

25 thereto a second redundancy information (dotted area) to form a matrix of size n^xn^. The systematic part is represented 
by the blank area of size A^xfc^ 

[0007] In general, an error correcting code is denoted (N,K,D) where N is the size of the code, K is the size of the 
original information (i.e. the size of the systematic information in case of a systematic code) and D is the minimum 
Hamming distance of the code. If (n v k v d^) and (n 2 , 1%, oy are respectively the block codes used by the first and the 
30 second block coders, the resulting turbo-code is in fact a product code of minimum Hamming distance d=d^xa^ and 
therefore denoted (/ijxife, frjxAg, o^xdy. Hence, by concatenating block codes of small Hamming distances a block 
turbo-code can be obtained with a much larger Hamming distance. 

[0008] The coded data output by the block turbo-coder is M-ary or binary modulated (e.g. BPSK modulated) prior to 
being transmitted over a transmission channel. At the receiving side, a demodulator outputs soft values reflecting the 
35 probabilities of transmitted M-ary symbols or bits. These soft values can be labelled in terms of probabilities, likelihood 
ratios or, more commonly, in terms of log likelihood ratios (LLRs). 

[0009] Fig. 2 illustrates schematically the structure of a block turbo-decoder. The information is presented as a P- 
dimensional block of soft values supplied by the demodulator. The turbo-decoding process involves a series of iterations 
1 ,..,k, upon the input block, each iteration consisting in a concatenation of elementary decoding steps, each elementary 

40 decoding step operating on one dimension of the input block. For example, (I) in Fig. 2 represents the concatenation 
of elementary decoding steps (or elementary decoders) 21o| 1) ,..,21 0 ( * of the first iteration and (ft) represents the 
concatenation of the elementary decoding steps (or elementary decoders) 210 (<f) ,..,21 0 W of the last iteration. The 
last iteration is followed by a hard decision 220, e.g. a thresholding, for obtaining the decided bits or words. 
[001 0] The input information of an elementary decoder is so called a priori information and consists of a noisy version 

45 of the output of the corresponding elementary coder. From this information and the coding law of the corresponding 
elementary coder, the elementary decoder generates an a posteriori information, which is an estimation of higher 
reliability of the information input to the corresponding elementary coder. The additional information provided by the a 
posteriori information with respect to the a priori information is referred to as extrinsic information. 
[001 1 ] Various algorithms can be used in the elementary decoders 21 0 W , for example the Chase algorithm disclosed 

so jn the article entitled "Near optimum product codes' 1 published in Proc.'lEEE Globecom of 1994, pages 339-343, or 
the algorithm described in the article of J. Lodge et al. entitled "Separate MAP filters for the decoding of product of 
concatenated codes" published in Proc. ICC'93 , pages 1740-1745. 

[0012] Each elementary decoder receives the entirety of the input block and carries out an estimation of the soft 
values of the said block, according to the coding dimension of the corresponding elementary coder, by using for example 
55 the Chase algorithm mentioned above. If the soft values are expressed in terms of LLRs, the a posteriori information 
output by the decoder is subtracted from the a priori information to obtain a block of extrinsic information having the 
same size as the input block. The extrinsic information is then added to the input block to serve as a priori information 
for the next elementary decoder. It should be noted that the order of the elementary decoders/decoding steps is of a 
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little importance, each operating on one orthogonal dimension of the n-dimensional block. By successive passes from 
one dimension to another and from one iteration to the next one, the estimation of the systematic information gains 
reliability. 

[0013] More specifically, the structure of an elementary decoder decoding the pth dimension is represented in Fig. 

s 3. The input block is represented by a matrix R of soft values supplied by the demodulator, assumed to be expressed 
here in terms of LLRs. The elementary decoder inputs a matrix of extrinsic values W p and outputs a matrix of extrinsic 
values Wp^, the matrix of extrinsic values input by the first decoder at the first iteration being W^O. The extrinsic 
values are then weighted in 31 0 by a weighting factor a p before being added to the soft values of the matrix R. The 
purpose of the weighting factor a p is to reduce the contribution of the extrinsic information, the reliability of which is 

io low during the first iterations. The resulting matrix R p of soft values can therefore be written: 

R p =R + cc p .W p (1) 

[0014] The soft values are decoded in 330 e.g. by using the Chase algorithm, thus providing an a posteriori infor- 
mation of higher reliability represented by a matrix R' p of soft values. A new matrix of extrinsic values is obtained by 
subtracting in 340 the a priori information to the a posteriori information, that is: 

20 W p+1 =R' p -R p (2) 

[0015] At the last iteration, the systematic part of R' p is threshplded in the hard decision unit 2. 
[0016] An important chara mw i bl l i - o f art error cprre a il KJ Uu&'frinMmmu ( N;K;E#\sthe ratio R=KIN , called the 
code rate, which gives the coding efficiency of the code. The parameters of a product code of elementary codes {n^ 
kp,d p ), denoted 
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(npkpdp) are given by: 



35 r r JL 



N =n»; K =Tl k ; HHK (3) 

p~\ p-i 



and therefore: 



where r p -kptn p is the code rate of the pth elementary code. 

[0017] Another important characteristic of an error correcting code is the so called asymptotic gain of the code, 
defined as the ratio, expressed in decibels, of the energies per information bit E b which are necessary, without coding 
and with coding, respectively, for achieving a given binary error rate (BER). The asymptotic gain G of a product code 
is equal to the sum of the asymptotic gains of the elementary codes: 



55 P=\ 



G = £ G p (4) 

/>=■ 

[0018] In practice, fora given telecommunication system, the values of the parameters /Cand Wot an error correcting 
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code are often imposed. On the other hand, the parameters n p and k p oi the known block codes (n^k^dp) cannot take 
but few possible values. It follows (3) that a block turbo-code offers a very limited choice in terms of available parameters 
K and N. Furthermore, it is often found necessary to adapt the error correcting code parameters to the condition of the 
transmission channel. For example, if the quality of the transmission channel is good , a code of high rate can be 
5 chosen whereas if the quality of the transmission channel is poor, a code of low rate is required. In order to broaden 
the choice of values for the parameters K and N of a block turbo-code, the general techniques of code shortening, 
code puncturing can be applied. 

[0019] The shortening of a block code {n,k,d) consists in setting to zero a plurality s of bits (called shortened bits) of 
the information to be coded. Although these zero values are taken into account for generating the redundancy part, 
10 they are not transmitted to the receiver. The k-s remaining bits of the systematic information and the n-k bits of the 
redundancy information define a shortened code (n-s,k-s,cF) where d^d. At the receiving side, the decoder knows the 
positions and values (equal to 0) of the shortened bits and therefore they can be given the highest level of reliability 
(i.e. -1 if LLRs are used). The a priori knowledge of the s shortened bits improves the decoding of the n-s remaining 
bits. Shortened block codes can be concatenated to form a shortened block turbo code denoted 
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(n p - Sp,k p - Sp,<f). Typically, the shortened bits are arranged along rows and columns to simplify the decoding process. 
Fig. 4 shows ar? example of such a bidimensional shortened block turbo code. The shortened bits set to zero have 
been illustrated by the areas filled4n greyt The parameters otthe. illustrated shortened code are 

(fa - *l ) X ("2 " * 2 H*I " *l )* (*2 - *2 )>< * d* 2 ) 

and hence the rate of the shortened code is lower than the rate of the original code: 

**r {n ,-s M n r s 2 ) <R < 5 > 

[0020] The puncturing of a code consists in omitting to transmit certain bits of the code, most often belonging to the 
35 redundancy part if the code is systematic. At the receiving side, the punctured bits are attributed any value and the 
lowest reliability level (0 if LLRs are used). 

[0021] Fig. 5 shows a punctured bidimensional block turbo code. The punctured bits are represented by squares 
filled in black. If x is the total number of punctured bits, the parameters of the punctured code are (n^./t^-x,^*) with 
&<d and the rate of the punctured code is higher than rate of the original code: 

40 

k* ko 

R x = > Ft (6) 

* n A n 2 -x x ' 

45 [0022] Since the number of parity bits is lower and since the punctured bits have the lowest reliability level, the gain 
of the punctured code is lower than the gain of the original code. 

[0023] The combination of shortening and puncturing significantly extends the choice of achievable parameters. In 
particular, for a shortened and punctured bidimensional block turbo-code, the parameters are 



(fa -*,)*fa 2 ^ 2 )-*,fa -j.M* 2 -5,X<x«/;) 

and therefore the code rate can be written : 



* (n,s,)(n 2 -s 2 yx W 
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[0024] By carefully choosing the parameters of the elementary block codes, the shortening lengths and the amount 
of punctured bits, the desired parameters N,Kcan be obtained. These codes are called parametric block turbo-codes. 
[0025] However, the larger choice of parameters is balanced by the lower asymptotic gains of the codes obtained, 
basically due to puncturing. 

5 [0026] it has been proposed in the prior art, e.g. in EP-A-827285, to distribute uniformly the shortened bits along the 
different dimensions of the turbo-code and next to the punctured bits. Such a turbo-code is illustrated in Fig. 6 where 
the punctured bits are represented in black and the shortened bits in grey. By so doing, the high reliability of the 
shortened bits compensates for the low reliability of the punctured bits and consequently improves the asymptotic gain 
value of the shortened punctured turbo-code. However, the puncturing necessary implies a waste of redundancy and 

io therefore a sub-optimal asymptotic gain. 

[0027] It is therefore a first object of the invention to obtain from a block turbo-code an error correcting code having 
the desired parameters N,K and exhibiting a higher gain than in the prior art. A second object of the invention is to 
obtain said error correcting code of desired parameters without puncturing. 

[0028] The object of the invention is achieved by the method defined in claim 1 . The object of the invention is also 
is defined by the decoding method set out claim 7. 

[0029] The characteristics of the invention mentioned above, as well as others, will emerge more clearly from a 
reading of the following description in relation to the accompanying figures, amongst which: 

Figs. 1 depicts schematically the general structure of a block turbo-coder; 
20 Fig. 2 depicts schematically the general structure of a block turbo-decoder; 

Fig. 3 depicts schematically the strcuture of an elementary decoder for one dimension of the turbo-code ; 
Fig. 4 represents a bidimensional shortened block turbo-code; 
Fig. 5 represents^ bidimensional punctured block turbo-code;. 

Fig. 6 represents a bidimensional shortened and punctured block turbo-code according to the prior art; 
25 Figs. 7A and 7B represent two steps of the method according to the invention for obtaining an error correcting 

code of parameters N,K t starting from a bidimensional block turbo-code; 

Fig. 8 depicts schematically a coder according to the invention for generating said code of parameters N,K; 
Fig. 9 depicts schematically a decoder according to the invention for decoding the code generated by the coder 
of Fig. 8; 

30 Fig. 1 0 illustrates the BER for a block turbo-code according to the invention and a conventional block turbo-code, 

respectively; 

Fig. 11 illustrates the PER for a block turbo-code according to the invention and a conventional block turbo-code, 
respectively. 

35 [0030] The general idea at the basis of the invention is to jointly use a combination of code shortening and bit stuffing, 
the stuffing bits being obtained by applying an additional error correcting code to the shortened block turbo-code. 
[0031] In general, bit stuffing consists in adding, e.g. appending dummy bits to a codeword to be transmitted. At the 
receiver side, the stuffing bits are stripped away from the codeword and the decoding process operates on the remaining 
bits. If (n,k,d) are the parameters of a block code and z is the number of stuffing bits, the parameters of the stuffed 

40 code are (n+z,k,d) and the new code rate is therefore lower than the original code rate: 




(8) 



45 [0032] Let us suppose that an error correcting code of given parameters N, K is required and that two systematic 
block codes of parameters (n 1( fc,, d,) and {r^, k^ dy respectively are chosen such that: 



k^>K 



(9.1) 



50 



n^n 2 >: N 



(9.2) 
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and, if a minimum coding gain G mJn is required,. such that they also meet the constraint 



G, + G 2 > G r 



r min 



(9.3) 
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[0033] The product code or block turbo-code, (ny, k v dy)x(n 2t Jfe, dy has a codelength of bits and comprises 
ky 1% systematic bits. In order to obtain the desired amount of /(systematic bits, kyf^-K systematic bits must be removed 
or, in other words, shortened. 

[0034] As we have already seen above, shortening can be achieved by setting entire rows and/or columns and/or 
5 isolated bits to zero. If Sy columns and Sg rows of the product code are shortened, the amount of systematic bits 
shortened in the row/column shortening operation is: 



kfa - - SjMfc, - + /^s 1 - s A s 2 (10) 

10 

and the total amount of row/column shortened bits: 



"1^2 -s 1 )(r>2-s 2 ) =n i s 2 +n 2 s i - s i s 2 

15 

[0035] The remaining amount of isolated systematic bits to be shortened in order to obtain /(systematic bits is there- 
fore: 



20 /r 1 /r 2 -(/r 1 s 2 +A 2 s 1 -s 1 s 2 )-/C (12) 

[0036] After having shortened said isolated systematic bits, the codelength becomes, taking into account (11) and 
(12): 

25 

n s = n y n 2 ~(nyS 2 + n 2 Sy - s,s 2 ) - (k^- {k,s 2 + fc^ - SyS^-K) (13) 



that is: 

30 

n s = nyn 2 - s 2 (n^ - ky)- Sy(n 2 - fc>) - (k^ - K) (14) 

[0037] Only the first term in (14) is positive. It is assumed that Sy , Sg are chosen so that n s £N. 
^ [0038] According to the invention, stuffing bits in an amount of: 

N-n s = {kyk 2 -K)- (nyn 2 - A0+%(#v ky)+Sy{n 2 - fc>) (12) 



40 are inserted after the code shortening step. The stuffing bits are obtained by applying an error correction code (referred 
to in the following as additional error correction code) to the shortened code. Advantageously, a simple code is chosen 
as additional error correction code, for example a replication code or a parity code. 

[0039] Figs. 7A and 7B illustrate with an example how the desired code of parameters N,K\s obtained from the block 
turbo-code (n 1t ky t dy)x{n 2 , 1%, dfe). 
45 [0040] Fig. 7A shows the result of the bit shortening step, where the shortened bits are represented in dark grey. 
Here, five rows and no column have been shortened (s 1 =0 and s^=5) as well as bits uniformly distributed along the 
two dimensions of the code (see diagonals). It is emphasized that the shortened bits are not transmitted but are taken 
into account for the calculation of the redundancy part of the product code. 

[0041 ] Fig. 7B shows the result of the bit stuffing step, where the stuffing bits are represented in light grey. According 
50 to an embodiment of the invention, the stuffing bits take the place of some of the shortened bits, in the amount given 
by (1 5). According to a first variant, the stuffing bits are scattered pseudo-randomly over the systematic part. According 
to a second variant, the stuffing bits are distributed according to a regular uniform distribution law over the systematic 
part, e.g. along the diagonal or diagonals thereof. It is emphasized that the stuffing bits are not taken into account for 
the calculation of the redundancy part of the product code but are transmitted though . 
55 [0042] The stuffing bits are obtained by applying said additional correcting code. For example, each stuffing bit can 
be a replicate of its right neighbour as indicated by arrow 610. 

[0043] A numerical example will better explain the shortening and bit stuffing process according to the invention. Let 
us assume that we have to realize a coder which inputs K=424 bits and outputs A*=832 bits, i.e. which has an imposed 
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code rate of ft= 424/832=0.51 . 

[0044] Let us now consider a turbo-code consisting in the concatenation of two identical BCH (32,26,4) codes. The 
constraints 9.1 and 9.2 are met since 26*>424 and 32 2 >832. The amount of systematic bits to be shortened is 262- 
424=252. Let us further assume that S2=6 rows and no column are shortened. The amount of isolated systematic bits 

5 to be shortened is therefore 252-6x26=96 bits. The total amount of shortened bits is equal to the sum of the number 
of bits (systematic and redundant) of the shortened rows and the number of the shortened isolated systematic bits, 
that is: 32x6+96=288 bits. After the shortening step, the total amount of remaining bits is equal to: 32 2 -288=736 bits. 
This amount is lower than the desired codelength 832 and therefore 832-736=96 stuffing bits are inserted in the short- 
ened code, for example at the locations of the 96 shortened systematic brts. Each stuffing bit is preferably a replicate 

10 of a neighbouring bit. 

[0045] Fig. 8 shows schematically the structure of a coder according to the invention allowing to obtain a code of 
parameters N,K starting from a block turbo-code {n v k v cf^xf/^, k^ dy. In module 810, the K information brts as well 
as zeros at the locations of the shortened bits are arranged in a k A xk^ matrix. The concatenated coders 820 and 830 
carry out the (n^ k v d,) and (r^, *g. ofe) coding respectively. The bits to be shortened (rows, columns and "isolated" 
is bits) are removed in 840. The additional correcting code is applied in 850 to the shortened turbo-code output from 840. 
The N-n s error correcting bits thus obtained are used in 860 for stuffing the turbo-code at predetermined locations. The 
stuffed shortened turbo-code contains the required amount of N bits. 

[0046] Fig. 9 shows schematically the structure of a decoder according to the invention. The decoder receives after 
demodulation a block of N soft values. The N-n s stuffed values are used in the soft pre-decoder 91 0 for error correcting 

20 the shortened turbo-code . Forexample, if the stuffed brts are replicates of information bits and the soft values expressed 
as LLPs, the soft value of an information bit is averaged with the soft value of its replicate in order to obtain an estimation 
of higher reliability. After pre-decoding, the soft values corresponding to the stuffed bits are removed from the received 
block in 920. Zeros- Wiethe highest. reliability- level arc inserted in 930 at the lorations^lthe shortened bits, i.e. -1's 
are inserted if LLPs are used. The iterative turbo-decoding process is performed in 940 and the shortened bits are 

25 then removed in 950 to output a block of K bits. 

[0047] Fig. 1 0 shows the BER (Bit Error Rate) versus E</N for the example of the shortened BTC (832,424) set out 
above. The curve (1 01 0) relates to the shortened BTC without bit stuffing and the curve (1 020) relates to the shortened 
BTC stuffed with replicates. As it can be seen by comparing curves (1 01 0) and (1 020), the insertion of the stuffing bits 
significantly improves the BER. 

30 [0048] Fig. 11 shows the PER (Packet Error Rate) versus E^/N for the same example. The curve (1110) relates to 
the shortened BTC without bit stuffing and the curve (1120) relates to the shortened BTC stuffed with replicates. As it 
can be seen by comparing curves (1110) and (1120), the insertion of the stuffing bits significantly improves the PER. 
[0049] Although the code of parameters N,K has been obtained from a bidimensional block turbo-code, it should be 
clear to the man skilled in the art that a block turbo-code of higher dimension could have been used instead. 

35 [0050] It should also be clear that the various modules of the coder illustrated in Fig. 8 have been introduced for 
explanatory purposes only. In practice, the coder can be realised by a plurality of processors, each carrying out one 
or a plurality of coding steps, or by a single processor performing them all. This remark applies equally to the decoder 
of Fig. 9. 

40 

Claims 

1 . Method for obtaining an error correcting code of a given first size (A/), including a systematic information part of a 
given second size (K) and a redundancy part, according to which a block turbo-code is first obtained from said 

45 systematic information part and from predetermined information elements provided at known locations, said block 

turbo-code consisting in a product of elementary systematic block codes, at least said predetermined information 
elements being removed from the obtained block turbo-code to produce a shortened block turbo-code, charac- 
terised in that an additional error correcting code is derived from at least a portion of said shortened block turbo- 
code and that said shortened block turbo-code is stuffed with stuffing elements so as to attain said given first size, 

50 said stuffing elements being information elements of said additional error correcting code. 

2. Method for obtaining an error correcting code according to claim 1 , characterised in that said stuffing elements 
are information elements of the redundancy part of said additional error correcting code. 

55 3. Method for obtaining an error correcting code according to claim 2, characterised in that said error correcting 
code is a replication code. 

4. Method for obtaining an error correcting code according to any preceding claim, characterised in that said stuffing 
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elements are inserted in the block turbo-code at locations where the predetermined information elements have 
been removed. 

Method for obtaining an error correcting code according to claim 4, characterised in that the information elements 
of said error correcting code are inserted according to a pseudo-random pattern. 

Method for obtaining an error correcting code according to claim 4, characterised in that the information elements 
of said error correcting code are inserted according to a uniform regular pattern. 

Method for decoding an error correcting code obtained by a method according to any preceding claim, charac- 
terised In that, said error correcting code being provided by a demodulation step as a first block of soft values, a 
soft pre-decoding step using the soft values corresponding to said stuffing elements is effected to produce a second 
block of soft values of higher reliability, a removing step where the soft values corresponding to said stuffing ele- 
ments are removed from said second block, said predetermined information elements are then inserted in said 
second block at said known locations as soft values of highest reliability to produce a third block of soft values, 
said third block of soft values is turbo-decoded and said predetermined information elements are removed from 
said turbo-decoded block to produce a systematic information part having said given second size. 

Coder for coding a block of information elements having a given second size (K) into an error correcting code 
having a given first size (A/), the coder comprising means (810) for inserting at known locations predetermined 
information elements, means (820,830) for turbo-coding the resulting block by applying a product of elementary 
systematic block codes, means (840) for removing at least said predetermined information elements from the 
turbo-coded block to produce a shovtenadblock turbo-code, characterised by comprising additional error correc- 
tion coding means (850) for coding at least a portion of said shortened block turbo-code and stuffing means (860) 
for stuffing said shortened block turbo-code with information elements of said additional error correcting code. 

Decoder for decoding a first block of soft values corresponding to an error correcting code generated by a coder 
according to claim 8, said decoder comprising means (910) for performing a soft pre-decoding step using the soft 
values corresponding to the stuffing elements and for producing a second block of soft values of higher reliability, 
means (920) for removing from said second block the soft values corresponding to said stuffing elements, means 
(930) for inserting in said second block predetermined information elements with the highest reliability level at said 
known locations to produce a third block of soft values, means (940) for turbo-decoding said third block of soft 
values and means (950) for removing from said turbo-decoded block said predetermined information elements to 
produce an information block having said second size. 
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